@import "~scss/_mixins";

.menus {
	.menuWrap { position: absolute; left: 0px; top: 0px; width: 100%; z-index: 23; }

	.menuWrap.fromChat,
	.menuWrap.fromBlock,
	.menuWrap.fromGraph { z-index: 25; }

	.menuWrap.fromPopup, 
	.menuWrap.fromHeader, 
	.menuWrap.fromSidebar,
	.menuWrap.fromOnboarding { z-index: 1001; }

	.menuWrap.fixed { position: fixed; }
	.menuWrap.fixed {
		.menu { position: fixed; }
	}

	.dimmer { position: fixed; left: 0px; top: 0px; width: 100%; height: 100%; background: rgba(0,0,0,0); -webkit-app-region: no-drag; }
	#menu-polygon { z-index: 1000; position: absolute; }

	.menu * { user-select: none; }
	
	.menu { 
		border-radius: 8px; position: absolute; z-index: inherit; text-align: left; backface-visibility: hidden;
		box-shadow: 0px 4px 16px rgba(0, 0, 0, 0.2); background: var(--color-bg-primary); opacity: 0; transform: scale3d(0.95,0.95,1);
		transition-duration: 0.15s; transition-timing-function: $easeInQuint; transition-property: opacity, transform;
	}
	.menu.fixed { position: fixed; }
	.menu * { user-select: none; }

	.menu.show { opacity: 1; transform: scale3d(1,1,1); }
	
	.menu.v1.h3 { transform-origin: 0% 100%; } /* left top */
	.menu.v2.h3 { transform-origin: 0% 0%; } /* left bottom */
	
	.menu.v1.h4 { transform-origin: 100% 100%; } /* right top */
	.menu.v2.h4 { transform-origin: 100% 0%; } /* right bottom */
	
	.menu.v1.h5 { transform-origin: 50% 100%; } /* center top */
	.menu.v2.h5 { transform-origin: 50% 0%; } /* center bottom */
	
	.menu.v5.h3 { transform-origin: 0% 50%; } /* left center */
	.menu.v5.h4 { transform-origin: 100% 50%; } /* right center */
	
	.menu {
		.input { user-select: text; }
		
		.arrowDirection { 
			width: 17px; height: 8px; transition: none; background-image: url('~img/arrow/menuDirection.svg');
			position: absolute;
		}
		.arrowDirection.c1 { top: -7px; }
		.arrowDirection.c2 { bottom: -7px; transform: rotateZ(180deg); }
		.arrowDirection.c3 { left: -11.5px; transform: rotateZ(-90deg); }
		.arrowDirection.c4 { right: -11.5px; transform: rotateZ(90deg); }
	}
	
	.menu.vertical { width: var(--menu-width-common); }
	.menu.vertical {
		.content { overflow-y: auto; overflow-x: hidden; max-height: 368px; padding: 8px 0px; border-radius: inherit; transform: none; }
		.ReactVirtualized__List { padding: 8px 0px; }

		.loaderWrapper { 
			position: absolute; left: 0px; top: 0px; z-index: 20; width: 100%; height: 100%; border-radius: 12px;
			background: var(--color-bg-loader);
		}

		.tabs { padding: 10px 16px; border-bottom: 1px solid var(--color-shape-secondary); white-space: nowrap; font-weight: 700; color: var(--color-control-active); }
		.tabs {
			.tab { display: inline-block; vertical-align: top; transition: $transitionAllCommon; margin-right: 16px; position: relative; }
			.tab:hover, .tab.active { color: var(--color-text-primary); }
			.tab:last-child { margin: 0px; }
		}

		.titleWrapper { display: flex; gap: 0 6px; padding: 8px 16px 0px; align-items: center; }
		.titleWrapper {
			.icon.back { width: 20px; height: 20px; background-image: url('~img/arrow/menu.svg'); transform: rotateZ(180deg); }
			.title { @include text-common; @include text-overflow-nw; font-weight: 600; color: var(--color-text-primary); padding: 0; }
		}
		
		.inputWrap { padding: 0px 16px 8px 16px; }
		.input { border: 1px solid var(--color-shape-secondary); padding: 0px 8px; }
	
		.title { @include text-small;  margin: 0px; padding: 7px 16px; font-weight: 400; color: var(--color-control-active); }

		.separator .inner { margin: 8px 16px 7px 16px; height: 1px; background: var(--color-shape-secondary); }
	
		.item { padding: 4px 16px; @include text-common; line-height: 20px; position: relative; width: 100%; background: var(--color-bg-primary); }
		.item.isDragging::before { box-shadow: 0px 1px 5px rgba(0, 0, 0, 0.2); }
		.item.isReadonly { cursor: default; }
		
		.item::before { 
			content: ""; position: absolute; left: 8px; top: 0px; width: calc(100% - 16px); height: 100%; background: rgba(79,79,79,0); z-index: 1; pointer-events: none; 
			border-radius: inherit; border-radius: 6px;
		}
		.item.hover::before { background: var(--color-shape-highlight-medium) !important; }
		.item.hover, .item:hover {
			.icon.delete, .icon.more { opacity: 1; }
		}
		.item.withMore.hover, .item.withMore:hover {
			.clickable { padding-right: 28px; }
			.caption { opacity: 0; }
		}

		.item.isReadonly::before { transition: none; }
		.item.isReadonly.hover::before, .item.isReadonly:hover::before { opacity: 0; background: none; }

		.item.add { line-height: 20px; }

		.item {
			.name { display: inline-block; vertical-align: top; position: relative; line-height: 20px; }

			.icon { width: 20px; height: 20px; margin-right: 6px; vertical-align: top; transition: none; flex-shrink: 0; }

			.icon.dnd { width: 20px; height: 20px; background-image: url('~img/icon/dnd.svg'); margin: 0px; vertical-align: top; cursor: grab; }
			.icon.plus { margin-right: 6px; background-image: url('~img/icon/plus/menu0.svg'); }
			.icon.delete, .icon.more { 
				width: 24px !important; height: 24px !important; background-size: 20px; position: absolute; right: 10px; top: 50%; margin: -12px 0px 0px 0px; 
				border-radius: 4px; opacity: 0; z-index: 1;
			}
			.icon.delete { background-image: url('~img/icon/menu/delete.svg'); }
			.icon.delete:hover, .icon.more:hover { background-color: var(--color-shape-highlight-medium); }
			.icon.arrow { width: 20px; height: 20px; position: absolute; right: 8px; top: 50%; margin: -10px 0px 0px 0px !important; background-image: url('~img/arrow/menu.svg'); }
			.icon.chk { width: 20px; height: 20px; position: absolute; right: 8px; top: 50%; margin: -10px 0px 0px 0px; background-image: url('~img/icon/menu/chk.svg'); }
			.icon.sortArrow { width: 20px; height: 20px; margin: 0px; background-image: url('~img/icon/menu/sortArrow.svg'); }
			.icon.sortArrow.c1 { transform: rotateZ(180deg); }

			.buttons { flex-shrink: 0; }
			.buttons {
				.icon { position: static; margin: 0px; flex-shrink: 0; }
			}
			
			.iconObject { margin-right: 6px; vertical-align: top; flex-shrink: 0; }

			.clickable { display: flex; flex-grow: 1; overflow: hidden; width: 100%; align-items: center; }

			.select { height: 20px; padding-top: 0px; padding-bottom: 0px; }
			.select {
				.item { @include text-small; }
			}

			.highlightMark { top: 50%; margin-top: -5px; right: 16px; }
		}
		.item.sizeSmall { @include text-small; }
		.item.weightMedium { font-weight: 500; }

		.item.empty { cursor: default; }

		.item.withDescription { padding: 8px 16px; height: 56px; }
		.item.withDescription {
			.iconMain, .iconObject { width: 40px; height: 40px; border-radius: 6px; position: absolute; left: 16px; top: 8px; }
			
			.descr { @include text-small; @include text-overflow-nw; line-height: 20px; height: 20px; color: var(--color-text-secondary); }
			.descr:empty { display: none; }

			.info { line-height: 40px; }
			.txt { width: 100%; }
		}

		.item.withDescription.withIcon, 
		.item.withDescription.withIconObject {
			.info { padding-left: 52px; }
		}

		.item.withNote {
			.info { display: flex; align-items: center; gap: 0px 20px; width: 100%; }
			.icon.note { position: relative; flex-shrink: 0; width: 20px; height: 20px; margin: 0px; background: url('~img/icon/menu/important.svg'); }
		}

		.item.withCaption { display: flex; align-items: center; justify-content: space-between; gap: 0px 6px; }
		.item.withCaption {
			.iconObject { margin: 0px; }
			.iconObject, .icon.dnd { flex-shrink: 0; }
			.name { width: 100%; margin-right: 6px; }

			.clickable { flex-grow: 1; gap: 0px 6px; overflow: hidden; }
			.clickable {
				.icon { margin: 0px; }
				.name { margin: 0px; width: 100%; }
			}

			.caption { 
				@include text-overflow-nw; display: inline-block; vertical-align: top; color: var(--color-text-secondary); @include text-small; text-align: right;
				flex-shrink: 0; line-height: 20px; max-width: 30%;
			}

			.highlightMark { position: relative; top: auto; right: auto; margin: 0px 0px 0px 2px; flex-shrink: 0; width: 6px; height: 6px; }
		}

		.item.withCaption.withArrow {
			.caption { padding-right: 12px; }
		}

		.item.withCaption.withCheckbox {
			.icon.chk { display: none; }
		}

		.item.withSwitch, .item.withSelect { display: flex; align-items: center; justify-content: space-between; }
		.item.withSwitch, .item.withSelect {
			.clickable { display: flex; }
		}

		.item.withSortArrow { padding-right: 10px; }

		.line { height: 1px; margin: 8px 16px 7px 16px; background: var(--color-shape-secondary); }
		.sectionName { padding: 5px 16px; @include text-small; color: var(--color-text-secondary); font-weight: 500; @include text-overflow-nw; }
		
		.section { padding: 8px 0px 0px 0px; }
		.section::after { content: ""; height: 1px; margin: 8px 16px 0px 16px; background: var(--color-shape-secondary); display: block; }
		.section:first-child { padding: 0px; }
		.section:last-child { border: 0px; }
		.section:last-child::after { display: none; }
		.section > .name { padding: 3px 16px; margin-bottom: 2px; @include text-small; color: var(--color-text-secondary); display: block; font-weight: 500; }
		.section > .name:empty { display: none; }
		.section > .inputWrap { padding-bottom: 0px; }
		.section.noLine::after { display: none; }

		.input-drag-horizontal {
			.back { background-color: var(--color-shape-secondary); }
			.icon { 
				width: 12px; height: 12px; border-color: var(--color-shape-secondary); background-color: var(--color-bg-primary); 
				margin: 0px;
			}
			.fill { background-color: var(--color-orange); }
		}
	}

	.menu.horizontal {
		.content { display: flex; }
		.section { flex: auto; padding: 12px 18px; height: 44px; border-right: 1px solid var(--color-shape-secondary); white-space: nowrap; position: relative; }
		.section:last-child { border: 0px; }
		
		.icon { width: 20px; height: 20px; margin-right: 12px; }
		.icon:last-child { margin: 0px; }
		
		.icon {
			.icon.arrow { 
				width: 8px; height: 8px; background-image: url('~img/icon/menu/action/arrow0.svg'); position: absolute; right: 0px; top: 50%; 
				margin-top: -4px; background-size: contain;
			}
		}
		.icon.active {
			 .icon.arrow { background-image: url('~img/icon/menu/action/arrow1.svg'); }
		}
	}
}

html.platformWindows {
	.menus {
		.menu.vertical {
			.content { overflow-y: overlay; }
		}
	}
}

@import "./icon";
@import "./button";
@import "./help";
@import "./onboarding";
@import "./relation";
@import "./select";
@import "./smile";
@import "./type";
@import "./widget";
@import "./syncStatus";
@import "./graph";
@import "./participant";
@import "./publish";
@import "./tableOfContents";

@import "./search/object";
@import "./search/text";


@import "./calendar";
@import "./object";

@import "./identity";

@import "./preview/object";

@import "./block/common";
@import "./block/add";
@import "./block/context";
@import "./block/cover";
@import "./block/latex";
@import "./block/link";
@import "./block/linkSettings";
@import "./block/mention";
@import "./block/relation";

@import "./dataview/common";
@import "./dataview/create/bookmark";
@import "./dataview/file";
@import "./dataview/filter";
@import "./dataview/group";
@import "./dataview/object";
@import "./dataview/option";
@import "./dataview/relation";
@import "./dataview/sort";
@import "./dataview/source";
@import "./dataview/text";
@import "./dataview/view";
@import "./dataview/template";

@import "./chat/text";
